Money.h++ Code Example

Platforms: DOS, Windows, NT, OS/2, and UNIX workstations
Source and object code

Freedom from rounding errors

With Money.h++, the result balances

RWFixedDecimal52 debits="0";		The Rogue Wave RWDecimal types
RWFixedDecimal52 credits="0";		store fractions using base 10, so
debits+="1.00";				decimal fractions like 0.67 and 0.33
credits+="0.67";			are stored exactly, with no rounding
credits+="0.33";			error. Adding 67 cents and then adding
if(debits==credits)			33 cents is the same as adding a
cout<<"balances\n";			dollar! Because all of the arithmetic
else cout<<"doesn't balance\n";		is done exactly, the ledger balances.

With built-in C++ doubles, don't count on it

double debits = 0;			The built-in double types store 
double credits = 0;			fractions using base 2, so decimal
debits+=1.00;				fractions like 0.67 and 0.33 have 
credits+=0.67;				built-in rounding errors. Adding 67 
credits+=0.33;				cents and then adding 33 cents is not 
if(debits==credits)			the same as adding a dollar! Because 
cout<<"balances\n";			there is a built-in rounding error, 
else cout<<"doesn't balance\n";		the ledger doesn't balance.
Order now     Money.h++     Tools.h++

© Copyright 1995, Rogue Wave Software, Inc.